/**======================================================================================
 * 内容说明： 导入vue和elementui相关
 ======================================================================================*/
import babelpolyfill from 'babel-polyfill'
import Vue from 'vue'
import App from './App'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
/**======================================================================================
 * 内容说明： 导入router路由相关
 ======================================================================================*/
import VueRouter from 'vue-router'
import store from './vuex/store'
import Vuex from 'vuex'
import routes from './routes'

/**======================================================================================
 * 内容说明： 导入axios相关
 ======================================================================================*/
import axios from 'axios'
/**======================================================================================
 * 内容说明： 使用相关组件
 ======================================================================================*/
Vue.use(ElementUI)
Vue.use(VueRouter)
Vue.use(Vuex)
/**======================================================================================
 * 内容说明： 配置axios的全局基本路径全局属性配置
 ======================================================================================*/
axios.defaults.baseURL='http://localhost:1020/'
Vue.prototype.$http = axios
/**======================================================================================
 * 内容说明： 路由配置
 ======================================================================================*/
const router = new VueRouter({
  routes
})
/**======================================================================================
 * 内容说明： 路由前置拦截器，用作登录检查
 ======================================================================================*/
//添加Axios的前置拦截器：目的：让每一次的请求，都能携带token令牌
axios.interceptors.request.use(config => {
  //1. 从sessionstorage中取出token
  let token = sessionStorage.getItem("token");
  if (!token) {//如果为空，说明并没有登录
    //如果没有登录，则返回到登录页面。注意：在main.js中，是不能直接用this.，因为在main.js文件中，vue还没有被创建出来
    router.push({path: '/login'})
  } else {
    config.headers['token'] = token;
  }
  return config;
}, error => {
  Promise.reject(error);
})


router.beforeEach((to, from, next) => {
  //NProgress.start();
  if (to.path == '/login') {
    sessionStorage.removeItem('employee');
  }
  let user = JSON.parse(sessionStorage.getItem('employee'));
  if (!user && to.path != '/login') {
    next({ path: '/login' })
  } else {
    next()
  }
})

/**======================================================================================
 * 内容说明： 创建Vue对象，挂载 #app元素 ， 见Vue.app
 ======================================================================================*/


new Vue({
  //el: '#app',
  //template: '<App/>',
  router,
  store,
  //components: { App }
  render: h => h(App)
}).$mount('#app')